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(54) Access control system for files on a memory card 

(57) A communication device (100) can receive a 
smart card (106) to be accessible by a client module 
(102) via a smart card interface (104). The smart card 
has a file system including a plurality of data files and a 
control file. The control information from the control file 
is then read and based on the file control information, it 
is determined whether data read from a data file is 
authorized to include the data type of the data read 
therefrom. When it is determined that the data file is not 
authorized to include the data type, the data type is dis- 
carded. The technique allows for over-the-air provision- 
ing, alteration of carriers, services and protocols, 
availability of applications, and various others opera- 
tions pertaining to the configuration of communication 
devices in a secure and controlled manner. 
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Description 

BACKGROUND OF THE INVENTION 
5 1 . Field of the Invention 

[0001] The present invention relates to communication devices and, more particularly, to configuration of commu- 
nication devices. 

10 2. Description of the Related Art 

[0002] Today, various types of wireless communication devices are available. Examples of wireless communication 
devices include pagers, mobile phones, personal digital assistants (PDAs), palm-top computers, and electronic sched- 
ulers. 

15 [0003] Communication devices include software modules that control the operation of the communication devices. 
Given that communication devices are designed to be capable of operating with various different types of networks, 
these communication devices must be configured or provisioned in order to properly operate with respect to particular 
networks. Once properly configured, a communication device is able to access (and execute) services provided by the 
network. Access refers to both connectivity and to application access. Connectivity provisioning of a communication 

20 device includes access parameters such as phone numbers to remote access servers (RAS), authentication parame- 
ters, Short Message Service Center (SMSC) addresses, Internet Protocol (IP) or Mobile Station Integrated System Dig- 
ital Network (MSISDN) addresses of wireless access protocols (WAP) proxies. Without the connectivity and access 
parameters, it is impossible for the communication device to access services. Application provisioning includes config- 
uration of higher level concepts such as application level access to resources, specific software modules, channels, etc. 

25 Application provisioning can be used to define whether a service is allowed at all and, if allowed, with what restrictions. 
[0004] In some environments, communication devices can be pre-provisioned with connectivity configurations so 
that they are immediately able to access and execute services. However, more often the communication devices do not 
include such initial information and thus require that the configuration information be downloaded to the communication 
devices after the point of sales or the point of manufacturing. The communication information can be obtained by pro- 

30 visioning of the communication device using either a fixed link or an over-the-air mechanism. Still further, even after the 
communication devices are initially configured, it is often useful to have the ability to alter the configuration information 
during the lifetime of the communication device. 

[0005] It has heretofore not been possible to allow flexible configuration alteration while also providing protection 
for the configuration information. As a result, conventional communication devices essentially had static configurations 
35 and lacked ability to flexibly alter their configurations and/or did not provide sufficient control and security. 

[0006] Thus, there is a need for improved techniques for improved approaches to configuration of communication 
devices. 

SUMMARY OF THE INVENTION 

40 

[0007] Broadly speaking, the invention relates to improved techniques for controlled access to data stored in elec- 
tronic files in a data storage device. The data stored on the data storage device is used by an electronic device. The 
data storage device can take a variety of different forms including a semiconductor data storage device (e.g., hard drive, 
removable storage medium, smart card, PCCARD). The electronic device can be a variety of devices including a com- 

45 munication device, a server machine, a computing device, etc. The improved techniques use an access control system 
to restrict access to the files and data stored in the files. The access control system uses both file system access control 
and application layer protections to provide the restricted access to the files and the data stored therein. 
[0008] In one embodiment, the invention provides an easy way to configure and subsequently update such config- 
uration in communication devices, namely, wireless communication devices. The invention is thus suitable to permit 

50 updating of configuration information of a communication device in a secure and controlled manner. The invention also 
allows for over-the-air provisioning, alteration of carriers, services and protocols, availability of applications, and various 
other operations pertaining to configuration of the communication devices. 

[0009] The invention can be used in both fixed server and mobile client environments. In a server environment, the 
controlled file access provided by the invention can be used to control end user profiles, control server software profiles, 
55 etc. In a client environment, the controlled file access provided by the invention can be used to control service defini- 
tions, access parameters, application usage, etc. 

[0010] The invention can be implemented in numerous ways including, a method, system, device, and a computer 
readable medium. Several embodiments of the invention are discussed below. 
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[001 1] As a method for providing secure access to data stored in electronic files, the electronic files including a con- 
trol file and at least one data files, one embodiment of the invention includes the acts of: reading file control information 
from a control file; reading data from a data file, the data having a data type associated therewith; determining, based 
on the file control information, whether the data file is authorized to include the data type of the data read therefrom; 
5 and discarding the data of the data type read from the data file when the determining has determined that the data file 
is not authorized to include the data type. 

[0012] As a computer readable medium including computer program code for providing secure access to data 
stored in electronic files, one embodiment of the invention includes: computer program code configured to read file con- 
trol information from a control file; computer program code configured to read data from a data file, the data having a 
10 data type associated therewith; computer program code configured to determine, based on the file control information, 
whether the data file is authorized to include the data type of the data read therefrom; and computer program code con- 
figured to discard the data of the data type read from the data file when it is determined that the data file is not author- 
ized to include the data type. 

[0013] As a smart card for use with a communication device, one embodiment of the invention includes: a file sys- 
15 tern including a plurality of data files and a control file; and a controller operatively connected to the file system. The 
controller operates to provide the communication device with access to the file system. To control access to information 
stored in the file system, access privileges to the control file are limited, and the control file includes control information 
that defines particular types of information that are authorized to be stored in the data files. 

[001 4] As a file access control system for a file system, one embodiment of the invention includes: a plurality of data 
20 files, each of the data files capable of storing one or more data items; one or more control files describing authorized 
data items with respect to each of the data files; and an interface that enables a processing unit to access the plurality 
of data files and the one or more control files. 

[0015] As a data storage device for use with an electronic device, one embodiment of the invention includes a plu- 
rality of data files and a control file. Access privileges to the control file are limited, and the control file includes control 

25 information that defines particular types of information that are authorized to be stored in the data files. 

[0016] The advantages of the invention are numerous. Different embodiments or implementations may yield one or 
more of the following advantages. One advantage of the invention is that access to data stored in data files can be con- 
trolled using one or more control files to define what type of data is permitted in the data files. Another advantage of the 
invention is that an electronic device (e.g., communication device) can use data files to store configuration information 

30 for the device and thus allow update to the configuration of the device by altering the data stored in one or more of the 
data files in a controlled manner. Still another advantage of the invention is that the invention facilitates configuring or 
reconfiguring an electronic device (e.g., communication device) after its manufacture or sale. Yet another advantage of 
the invention is that generic files can be used to store the necessary configuration data in a flexible and secure manner. 
Another advantage of the invention is that configuration responsibilities can be shared by user and administrator. 

35 [0017] Other aspects and advantages of the invention will become apparent from the following detailed description 
taken in conjunction with the accompanying drawings which illustrate, by way of example, the principles of the invention. 

BRIEF DESCRIPTION OF THE DRAWINGS 

40 [0018] The invention will be readily understood by the following detailed description in conjunction with the accom- 
panying drawings, wherein like reference numerals designate like structural elements, and in which: 

FIG. 1 is a diagram of a client device according to one embodiment of the invention; 
FIG. 2 is a block diagram of a smart card according to one embodiment of the invention; 
45 FIGs. 3A and 3B are flow diagrams of client device configuration processing according to one embodiment of the 

invention; and 

FIG. 4 is a block diagram of a client device according to one embodiment of the invention. 
DETAILED DESCRIPTION OF THE INVENTION 

50 

[0019] The invention relates to improved techniques for controlled access to data stored in electronic files in a data 
storage device. The data stored on the data storage device is used by an electronic device. The data storage device 
can take a variety of different forms including a semiconductor data storage device (e.g., hard drive, removable storage 
medium, smart card, PCCARD). The electronic device can be a variety of devices including a communication device, a 
55 server machine, a computing device, etc. The improved techniques use an access control system to restrict access to 
the files and data stored in the files. The access control system uses both file system access control and application 
layer protections to provide the restricted access to the files and the data stored therein. 

[0020] In one embodiment, the invention provides an easy way to configure and subsequently update such config- 
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uration in communication devices, namely, wireless communication devices. The invention is thus suitable to permit 
updating of configuration information of a communication device in a secure and controlled manner. The invention also 
allows for over-the-air provisioning, alteration of carriers, services and protocols, availability of applications, and various 
other operations pertaining to configuration of the communication devices. Using the invention, it is thus possible to 
5 combine write-protected and write-access information to create a partially controlled configuration environment using 
the controlled configuration environment to configure wireless communication devices. 

[0021] The invention can be used in both fixed server and mobile client environments. In a server environment, the 
controlled file access provided by the invention can be used to control end user profiles, control of server software pro- 
files, etc. In a client environment, the controlled file access provided by the invention can be used to control service def- 

10 initions, access parameters, application usage, etc. 

[0022] The configuration information can be stored in files having fields. Files can be easily defined with read and 
write access privileges, and the files (and directories) provide a good abstraction to divide information into protected 
and non-protected sections. The invention facilitates defining access rights on a per file basis and thus allows some of 
the elements to be given more access protection and some of the elements to be given less access protection. 

15 [0023] Configuration protection requires trust in the file system so that access to the file where the fields are defined 
can be controlled. If a file can be written by someone, then he/she is also able to manipulate any piece of data in the 
file and thus alter the configuration. The invention uses both file system access control and application layer protections 
to provide the restricted access to the data in the files. 

[0024] Embodiments of this aspect of the invention are discussed below with reference to FIGs. 1 - 4. However, 
20 those skilled in the art will readily appreciate that the detailed description given herein with respect to these figures is 
for explanatory purposes as the invention extends beyond these limited embodiments. 

[0025] FIG. 1 is a diagram of a client device 100 according to one embodiment of the invention. The client device 
100 is a communication device such as a wireless telephone, wireless pager, a personal digital assistant (PDA), etc. 
[0026] The client device 100 includes client module 102 and a smart card interface 104. The client module 102 is 

25 a programming module that includes programming instructions performed by the client device 100 in order to function 
as desired. The client module 102 interacts with a smart card 106 through the smart card interface 104. More particu- 
larly, the smart card 106, upon being inserted into an opening or spot of the client device 100, becomes accessible to 
the client module 102 via the smart card interface 104. The smart card 106 can provide digital logic and controllers as 
well as memory storage for data and programming instructions. According to the invention, the smart card 106 stores 

30 files containing configuration information (e.g., configuration files). The organization and control over the configuration 
files as well as the use of these configuration files by the client device are discussed in detail below with respect to FIGs. 
2-4. 

[0027] FIG. 2 is a block diagram of a smart card 200 according to one embodiment of the invention. The smart card 
200 is, for example, suitable for use as the smart card 1 06 illustrated in FIG. 1 . 
35 [0028] The smart card 200 includes a controller 202 that manages the operation of the smart card 200. In one 
embodiment, the controller 202 can be a semiconductor integrated circuit chip that is provided on the smart card 200. 
The controller 202 manages access to information and resources provided on the smart card 200. Typically, the access 
to the information and resources is limited to secure at least some portion of the information or resources provided on 
the smart card 200. 

40 [0029] The smart card 200 also includes an interface 204 that interfaces the controller 202 to the smart card inter- 
face 104 of the client device 100 that received the smart card 200. The interface 204 can be a hardware interface or 
software interface, or some combination of hardware and software. 

[0030] Additionally, the smart card 200 includes a file system (or a resource system) that includes various files (or 
resources). In one implementation, the files provided in the file system on the smart card 200 provide configuration or 

45 provisioning information for use by the client device 100, i.e., a communication device. The file system provided within 
the smart card 200 includes, in one implementation, file A 206, file B 208, file C 210, file D 212, and a control file 214. 
The control file 21 4 is a secure file that identifies the particular type of configuration or provisioning information that can 
be provided in each of the files 206 - 212. Then, during use of the configuration or provisioning information provided by 
the file system on the smart card 200, the client device 100 is able to retrieve the configuration or provisioning in a 

so secure manner. 

[0031] The access rights for the control file 214 need to be very limited because access to the control file 214 pro- 
vides access to all the files 206 - 212 which contain the configuration and provisioning information. The access rights 
can be set in a number of ways, including: operating system provided access privileges, data signed by certificates or 
any other security/encryption mechanism, hardcoded in the device, etc. The access rights to the files 206 - 212 can be 
55 similarly restricted if desired but typically have less restrictive or extensive access protection. For example, a user or 
third parties might have access rights to write to the files 206 - 212 but not to the control file 214. Instead, only an 
authorized network administrator would, for example, be able to write to the control file 214. Any user, third party or 
administrator would, for example, be able to read the files 206 - 21 2 and the control file 214. As another example, some 
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of the files 206 - 212 a user or third party might have restricted write access provided by an operating system. In any 
case, the invention operates above and in addition to any access control provided by the operating system provided 
access privileges, certificates or any other security/encryption mechanism. 

[0032] In one embodiment, the files 206 - 21 2 are configuration data files and the control file 21 4 is a configuration 
5 control file. The configuration information is stored in the files 206 - 212 and is thus stored in multiple files. The config- 
uration information provided in the files 206 - 212 can be presented in a number of ways. For example, the configuration 
information can be presented in the files 206 - 212 as a descriptive language. As an example, the descriptive language 
can be a markup language where each file describes the content or information using a markup or tag-length-value 
method. The description language (e.g., XML, WBXML) defines elements, sub-elements and attributes which are used 
10 to describe characteristics of the configuration. The control file 214, or configuration control file, can similarly present 
configuration control information in a descriptive language. 

[0033] The control file 214, or the configuration control file, can describe the allowed content of any of the configu- 
ration data files (files 206 - 212) or describe the relation (i.e., what data is allowed to be combined with what other data) 
between data defined in the configuration data files. The control file 214 can also describe the interrelationship between 

15 files 206 - 21 2 and data within the files 206 - 212. The data, or configuration data, stored in the files 206 - 21 2 can con- 
tain descriptions of data needed to use the device. For example, one of the files 206 - 212 might contain all the config- 
uration data needed to use the service or might contain only part of the required configuration data. In cases where the 
file contains only partial descriptions of the needed configuration information, they can be logically linked with one or 
more other of the files 206 - 212. 

20 [0034] According to the invention, all the data (configuration data) read from the files 206 - 21 2 is verified with a set 
of rules provided in the control file 214 (configuration control file). The rules provided in the control file 214 can apply to 
one or more of the files 206 - 21 2 of the file system. For example, if the rules of the control file 214 say that only config- 
uration element X can reside in the file 206, then a definition of configuration element X is accepted as a valid configu- 
ration parameter when obtained from the file 206, but a definition of a configuration element Y is rejected when obtained 

25 from the file 206. For example, the rules provided in the control file 214 can be provided with descriptive semantics that 
allow reference to specific element types and, thus, to define the type of content that is allowed (or disallowed) in the 
files 206 - 212 of the file system. 

[0035] Using the invention, it is thus possible to combine write-protected and write-access information to create a 
partially controlled configuration environment using the controlled configuration environment to configure wireless com- 
30 munication devices. In one implementation, the control file and the data files are provided in a markup language, 
namely extensible Markup Language (XML). By combining XML pages in write protected files with XML pages in write 
access files, a secure configuration context can be achieved. 

[0036] As previously noted, the control file 214 and the files 206 - 212 can take many forms. Below are represent- 
ative examples of a configuration file and a configuration control file in an XML format. The configuration file pertains to 
35 a communication device that has multiple access paths to a single proxy. 

Configuration file: 



40 



file: wapconfl 
< ?xml version = " 1 .0" ? > 
<!DOCTYPE PROXY SYSTEM > 
< PROXY > 

<NET-UST ID=1 > 

< NETACCESS NAME = " First" DIALSTRING = " 1 23445"DIALPROT - " V1 1 0" 
45 ADDTYPE ="E1 64" NETID = "n1"> 

< /NETACCESS > 

< NETACCESS NAME = "SeconcTDIALSTRING = "1 2233"DIALPROT = "SMSC" 
ADDTYPE = "E1 64" NETID = "n2" > 
< /NETACCESS > 



50 



55 



< NETACCESS NAME = "Third" DIALSTRING « "009 1 23445" DIALPROT = " V1 1 0" 

ADDTYPE = "E1 64" NETID = "n3" > 

< /NETACCESS > 
< /NET-LIST > 
<PX-LIST ID=1 > 
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<PX-LOGICAL ID = "Carrier" > 

<PX-SERVICE NAME = "Brows" PXADDR= "1 23.145.024.1 23" 
ADDTYPE="IPV4" > 

< NETLINK TONETID = "n1" /> 

< NETLINK TONETID = "n3" /> 
</PX-SERVICE> 

<PX-SERV!CE NAME= "Brows" PXADDR="135" ADDTYPE = "GSM-SMS" > 

< NETLINK TONETID = "n2" /> 
</PX-SERViCE> 

</PX-LOGICAL> 
</PX-LIST> 
< /PROXY > 



File: wapconf2 

< ?xml version * " 1 .0" ? > 
<!DOCTYPE PROXY SYSTEM > 

< PROXY > 
<PX-LIST ID=1 > 

<PX-LOGICAL ID = "Premium" > 

<PX-SERVICE NAME = "Textus" PXADDR = " 1 23. 1 45.023" 
ADDTYPE="IPV4" > 

< NETLINK TONETID = "n1 " /> 

< NETLINK TONETID = "n3" /> 
</PX-SERVICE> 

<PX-SERVICE NAME = "Textus" PXADDR = "134" ADDTYPE = "GSM-SMS" > 

< NETLINK TONETID = "n2" /> 
</PX-SERVICE> 
</PX-LOGICAL> 
</PX-LIST> 
< /PROXY > 



Configuration Control File: 

< ?xml version = " 1 .0" ? > 
<!DOCTYPE PROXY SYSTEM > 

< PROXY-CONTROL > 
<PX-CONTROL FILE="wapconf1" > 

< ALLOWED ELEM = "NET-LIST'7> 
< ALLOWED ELEM = "PX-LIST"/> 
<LINK TOFILE = "any" /> 
</PX-CONTROL> 

<PX-C0NTROL FILE = "wapconf2 " > 
< ALLOWED ELEM = "PX-LIST'7> 
<LINK TOFILE = "wapconf1" /> 

</PX-CONTROL> 
< /PROXY-CONTROL > 



[0037] Although the data storage device discussed above in FIGs. 1 and 2 is a smart card, the data storage device 
need not be a smart card. For example, the data storage device could be a disk drive, a memory card (e.g., PCCARD), 
etc. The invention is also suitable for client device and server devices which sometimes use different data storage 
devices. In any case, when the data storage device does not include a controller such as a smart card, different mech- 
anisms are used to protect the integrity of the control file. These mechanisms, for example, can include encryption, 
operating system write protection, and/or hard-coding. 

[0038] FIGs. 3A and 3B are flow diagrams of client device configuration processing 300 according to one embodi- 
ment of the invention. The client device configuration processing 300 is, for example, performed by the client module 
102 of the client device 100 that is seeking to obtain configuration information from the smart card 106, 200. 
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[0039] The client device configuration processing 300 initially reads 302 configuration control information from a 
configuration control file. For example, the client module 102 would access the control file 214 through the interface 
104, 204 and the controller 202 such as illustrated in FIG. 2. Next, one of the configuration data files is selected 304. 
Here, with respect to FIG. 2, one of the files 206 - 212 is selected to be processed. 

5 [0040] After one of the configuration data files has been selected 304, the configuration data is read 306 from the 
selected configuration data file. For example, the configuration data is read from the selected configuration data file by 
the client module 1 02 through the interfaces 1 04, 204 and the controller 202 of the smart card 200. The configuration 
data has various configuration data types (content types) that serve to categorize the configuration data. Next, the con- 
figuration data types of the configuration data are compared 308 to the configuration control information. More particu- 

10 larly, the configuration data read from the selected configuration data file includes configuration data types for the 
configuration data. For example, the configuration data types can include any of carrier proxy, connection provisioning, 
encryption key, proxy address, address point address, capabilities, etc. These configuration data types are compared 
308 against the configuration control information provided by the configuration control file. 

[0041] A decision 31 0 then determines whether all of the configuration data types within the configuration data that 

15 has been read from the configuration data file are authorized. Here, as a result of the comparing 308, it is determined 
whether the configuration control information authorizes (or permits) the configuration data types provided in the 
selected configuration data file. If the decision 310 determines that all of the configuration data types provided in the 
selected configuration data file are not authorized, the configuration data associated with the unauthorized configura- 
tion data types is discarded 312. On the other hand, when all of the configuration data types provided in the selected 

20 configuration data file are authorized, the discarding 312 is bypassed because none of the configuration data needs to 
be discarded. When configuration data is discarded 312, the client device configuration processing 300 can simply 
silently reject the unauthorized configuration data, notify the user, or report same to a management entity. In any case, 
following the discarding 312 or following the decision 310 when all the configuration data types are authorized, the 
remaining configuration data that has been read 306 from the selected configuration data file is stored 314 in local 

25 memory for subsequent use by the client device. 

[0042] A decision 316 then determines whether there is another configuration data file to be processed. Typically, 
although not necessarily, the smart card 106, 200 includes more than one configuration data file. When the decision 
31 6 determines that there is another configuration data file to be processed, the processing returns to repeat the select- 
ing 304 and subsequent operations to process another of the particular configuration data files. On the other hand, 

30 when the decision block 316 determines that all of the configuration data files have been processed, the client device 
is configured 318 in accordance with the remaining configuration data that has been stored in the local memory. Here, 
the configuration of the client device operates to provision the client device, i.e., communication device, for access to 
services provided by a carrier. The carrier can be a wired carrier or a wireless carrier. Following the configuration 318 
of the client device, the client device configuration processing 300 is complete and ends. 

35 [0043] While the client device configuration processing 300 discussed above with respect to FIGs. 3A and 3B per- 
tains to reading information from a file system, similar processing can be perform prior to writing information to the file 
system. For example, if configuration data were to be written to a configuration data file, the device writing the data can 
first determines whether the configuration data file is authorized to store the type of data (e.g., type of configuration 
data) based on configuration control information provided by the configuration control file. Then, if not authorized, the 

40 write of the unauthorized can be prevented, thus saving memory storage capacity of the data storage device and also 
allowing software to recognize this fact at an earlier stage. 

[0044] FIG. 4 is a block diagram of a client device 400 according to one embodiment of the invention. The client 
device 400 can, for example, correspond to client device 100 illustrated in FIG. 1. 

[0045] The client device 400 includes a Universal Data Protocol (UDP) interface 402 that couples to a carrier net- 
45 work via a radio frequency (RF) transceiver 404 to receive incoming and outgoing signals. A device identifier (ID) stor- 
age 406 supplies a device ID to the UDP interface 402. The device ID identifies a specific code that is associated with 
a particular client device 400. In addition, the client device 400 includes a client module 402 that performs many of the 
processing tasks performed by the mobile device 400 including establishing a communication session with the carrier 
network, requesting and receiving data from a computer network (e.g., the Internet), displaying information on a display, 
50 and receiving user input. The client module 408 is coupled to the UDP interface 402 for the establishment of a commu- 
nication session and the requesting and receiving of data. The client module 408 also couples to a display driver 410 
that drives a display 412. The client module 408 controls the display driver 41 0 to display information on the display 41 2 
to the user. Additionally, the client module 408 is coupled to an input device 414, a ROM 416, and a RAM 418. Prefer- 
ably, among other things, the client module 408 operates a network browser, such as a Handheld Device Markup Lan- 
55 guage (HDML) web browser. The input device 414 allows a user of the client device 400 to input data and thus make 
selections in controlling and using the client device 400. The ROM 416 stores predetermined data and processing 
instructions for the client module 408. The RAM 418 is used to provide temporary data storage such as for incoming 
and outgoing data. 
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[0046] The client device 400 interacts with a smart card 422 through a smart card interface 420. The smart card 
422, upon being inserted into an opening or spot of the client device 400, becomes accessible to the client module 408 
via the smart card interface 420. The smart card 422 can provide digital logic and controllers as well as memory storage 
for data and programming instructions. According to the invention, the smart card 422 stores files containing configura- 
5 tion information (e.g., configuration files). The organization and control over the configuration files as well as the use of 
these configuration files by the client device 400 have been discussed above. 

[0047] The invention is preferably implemented in software, but can be implemented in hardware or a combination 
of hardware and software. The invention can also be embodied as computer readable code on a computer readable 
medium. The computer readable medium is any data storage device that can store data which can be thereafter be read 
10 by a computer system. Examples of the computer readable medium include read-only memory, random-access mem- 
ory, CD-ROMs, magnetic tape, optical data storage devices, carrier waves. The computer readable medium can also 
be distributed over a network coupled computer systems so that the computer readable code is stored and executed in 
a distributed fashion. 

[0048] The advantages of the invention are numerous. Different embodiments or implementations may yield one or 

15 more of the following advantages. One advantage of the invention is that access to data stored in data files can be con- 
trolled using one or more control files to define what type of data is permitted in the data files. Another advantage of the 
invention is that an electronic device (e.g., communication device) can use data files to store configuration information 
for the device and thus allow update to the configuration of the device by altering the data stored in one or more of the 
data files in a controlled manner. Still another advantage of the invention is that the invention facilitates configuring or 

20 reconfiguring an electronic device (e.g., communication device) after its manufacture or sale. Yet another advantage of 
the invention is that generic files can be used to store the necessary configuration data in a flexible and secure manner. 
Another advantage of the invention is that configuration responsibilities can be shared by user and administrator. 
[0049] Further, the invention enhances user trust in the communication device because the controlled file access 
and content type control makes it unlikely that its configuration has been tampered with. The invention is also advanta- 

25 geous in providing a communications carrier with greater control over the configuration of the communication device. 
[0050] The many features and advantages of the present invention are apparent from the written description and, 
thus, it is intended by the appended claims to cover all such features and advantages of the invention. Further, since 
numerous modifications and changes will readily occur to those skilled in the art, it is not desired to limit the invention 
to the exact construction and operation as illustrated and described. Hence, all suitable modifications and equivalents 

30 may be resorted to as falling within the scope of the invention. 

Claims 

1. A method for providing secure access to data stored in electronic files, the electronic files including at least one 
35 control file and at least one data file, said method comprising: 

(a) reading file control information from the control file; 

(b) reading data from the data file, the data having a data type associated therewith; 

(c) determining, based on the file control information, whether the data file is authorized to include the data 
40 type of the data read therefrom; and 

(d) discarding the data of the data type read from the data file when said determining step (c) determines that 
the data file is not authorized to include the data type. 

2. A method as recited in claim 1 wherein said method further comprises:- 

45 

(e) utilizing any of the data read from the data file that has not been discarded. 

3. A method as recited in claim 2 wherein said utilizing step (e) comprises configuring a wireless communication 
device in accordance with any of the data read from the data file that has not been discarded. 

50 

4. A method as recited in claim 3 wherein said configuring of the wireless communication device comprises provision- 
ing the wireless communication device for operation with a wireless carrier. 

5. A smart card for use with a communication device, the smart card comprising:- 

55 

a file system including a plurality of data files and a control file; and 

a controller operatively connected to said file system, said controller operating to provide the communication 
device with access to said file system; 
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wherein access privileges to the control file are limited, and wherein the control file includes control information 
that defines particular types of information that are authorized to be stored in the data files. 

A smart card as recited in claim 5 wherein the communication device reads information from the data files and then, 
before using any of the information, discards that portion of the information that pertains to a type of information not 
authorized to be stored in the respective data files. 

A file access control system for a file system, said file access control system comprising :- 

a plurality of data files, each of said data files capable of storing one or more data items; 
a control file describing authorized data items with respect to each of said data files; and 
an interface that enables a processing unit to access said plurality of data files and said control file. 

A file access control system as recited in claim 7 wherein said file access control system is provided in a wireless 
communication device that includes the file system. 

A data storage device for use with an electronic device, the data storage device comprising :- 

a plurality of data files; and 
a control file; 

wherein access privileges to the control file are limited, and wherein the control file includes control information 
that defines particular types of information that are authorized to be stored in the data files. 

A data storage device as recited in claim 9 wherein the electronic device reads information from the data files and 
then, before using any of the information, discards that portion of the information that pertains to a type of informa- 
tion not authorized to be stored in the respective data files. 
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